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A COMMUNICATION NETWORK COMPRISING A PLURALITY OF RECEIVERS WITH 
USER PROFILE DEPENDENT SELECTION OF PROGRAMMES 



Field of the Invention 

This invention relates to a communication system. More 
particularly, the present invention relates to a non-hierarchial 
network in which receivers are responsive to data objects which are 
10 broadcast network wide. 

Backgro und of the Invention 

In the prior art, there are communications systems for 
supplying video, audio and data to affiliated receivers in a network for 
15 broadcast or display. 

These known systems all comprise some form of 
addressing to identify the destination, i.e. receiver, for the video, audio 
or data transmission. The addressing scheme produces a single to 
multi-point network in which communication is provided between a 
2 0 transmitter and one or more receivers. 

These known systems have drawbacks. By its very nature, 
the addressing scheme requires that the transmitter must know the 
addresses of all the; receivers. This implies that the traiismitter must 
have considerable intelligence or processing power. In addition, each 

2 5 receiver must also include sufficient processing power to identify and 

decode transmissions which are addressed to it. Furthermore, the 
capacity of the system is dependent on the addressing scheme. Each 
additional receiver will be seen by the transmitter as an additional 
address which must be serviced. 

3 0 Therefore, there is a need for a system which provides a 

communication network in which receivers are responsive to data 
objects without the need for point-to-point addressing. 

SUBSTITUTE SHEET 



wo 95/08226 



PCT/CA94/00505 



-2- 

Brief Summary of the Invention 

A feature of the present invention is that the receivers 
process data independent of the transmitter. The system does not 
require the transmitter to address any of the receivers. Ixtstead, the 
5 transmitter broadcasts a stream of objects and each receiver selects any 
object according to a local profile. 

It is another feature of the present invention that the 
receivers can provide a number of different services. 

In a first aspect/ the present invention provides a 
10 communication system comprising: (a) a transmitter having means 
for transmitting an object stream comprising one or more objects; (b) a 
plurality of receivers each including means for receiving said object 
stream, and each including meai\s for selecting any of said objects 
from said object stream; (c) means for providing a receiver profile; (d) 
15 said receiver profile comprising a list of interest objects for said 
receiver; and (ej said means for selecting being responsive to said 
profile for selecting objects from said object stream corresponding to 
objects of interest. 

Brief Description of t he Drawings 

For a better tmderstanding of the present invention, and 
to show more clearly how it may be carried into effect, reference will 
now be made, by way of example, to preferred embodiments of the 
present invention shown in the accompanying drawings in which: 

Figure 1 shows in block diagram form a commimication 
system according to the present invention; 

Figure 2 is a detailed block diagram of a receiver for the 
system shown in Figure 1; 

Figure 3 is a functional block diagram showing the 
primary components of a computer program which controls the 
operation of the receiver of Figure 2; 

Figture 4 is a functional block diagram which shows the 



20 



25 



30 
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details of a data receptor module for the program of Figure 3; 

Figure 5 is a fimctional block diagram which shows the 
details of a sequencer module for the program of Figure 3; 

Figure 6 illustrates an exemplary profile which is used by 
5 the system of Figure 1; 

Figure 7 illustrates an exemplary cross-reference table for 
the profile of Figure 6; 

Figure 8 shows the structure of a stream of data objects 
which is received by the receiver of Figure 2; 

1 0 ; Figure 9 is a partial listing of an exemplary Sequence List 

according to the invention; 

Figure 10 shows an example "include" file for the 
Sequence list of Figure 9; and 

Figure 11 shows an exemplary Product I>efinitiori 
15 according to the invention. 

Detailed Description of the Preferred Embodiments 

Reference is first made to Figure 1 which shows in block 
diagram form an overview of a commimication system 2 according to 

2 0 the present invention. The communication system 2 comprises a 

communication controller 4, a transmitter 6, a communication 
channel 8, and a receiver 10 which comprises a coiiununication 
interface 12 and an on-line de-selector 14, 

The coirmumication controller 4 comprises a computer 
25 which is coupled to the transmitter 6^ The function of the 
commuiucation controller 4 is to transmit data objects to the receivers 
10. For the purposes of the following description, the receiver 10 is 
coupled to a cable television network 16. As shown in Figure 1, the 
cable television network 16 comprises a cable television station 18 and 

3 0 cable television subscribers 20 (e.g. households). In the context of a 

cable television network, the cable television station 18 is a client or 
user of services which are made available through the 
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communication network 2. As will be described in detail, the 
communication network 2 according to the present invention can be 
used to provide a number of different services, such as weather 
forecast, stock market reporting, and headline news for example. The 
5 cable television station 18 obtains access to these services through the 
receiver 10 and retransmits the service(s) to the subscribers 20 or 
households. 

In contrast to known systems, the communication 
controller 4 does not use an addressing scheme, instead the objects are 

10 broadcast into space and the receivers 10 accept the data, but only 
prociess data objects based on their individual requirements or 
interests- As will be described in below, an object can comprise digital 
or computer images, and textual data, related to, but not limited, for 
example weather, financial or headline news, and the information is 

15 transmitted as a stream of data objects. (In addition, as will be 
described, a live video feed signal and audio signal feed can be 
incorporated into the service which is provided by the receiver 10.) 
Each receiver 10 has a profile /scheduler which specifies the objects 
which are of interest to the receiver 10. The receiver 10 uses its 

2 0 profile/scheduler to "de-select" objects which are of interest to it from 
the continuous stream of objects existing in space;. Because each 
receiver 10 includes the mearis for determining which objects it is 
interested in, the communication controller 4 needs to know very 
little about the receiver 10, for example, the address or location of each 

2 5 receiver 10 is not required. It will be appreciated by those skilled in the 

art that this can simplify the design of the communication network. 

As shown in Figure 1, the communication controller 4 
can include an off-line support module 22. Because the system 2 
according to the present invention provides an open network 

3 0 architecture, i.e. receivers 10 existing in space without addresses, the 

controller 4 need not know much about the receivers 10. the primary 
task of the controller 4 is providing objects based on the interests of the 
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users or clients (e.g. the cable television station 18) of the system 2. 
Therefore, the support module 22 can comprise one or more databases 
for storing client information and lists of objects for management and 
inventory purposes. The objects themselves are supplied by an object 
source 23 and put into a form for transmission (e.g* TEFF format) by an 
object builder 25 which is coupled to the commxmication controller 4. 

Referring still to Figure 1, the transmitter 6 comprises 
communication equipment which is coupled to the controller 4. The 
transmitter 6 provides the interface between the controller 4 and the 
commimication channel 8. The transmitter 6 formats the data objects 
according to the standard and protocol utilized by the commxmication 
charmel 8. In the preferred embodiment of the present invention, the 
communication channel 8 comprises a satellite system. To 
communicate with the receivers 10, the satellite (communication 
system 8) uses a signalling charmel comprising a baseband signal 
(which provides the video and audio signal feeds) and includes data 
sub-carrier, e.g. 512 kiloBaud, for the data objects and another sub- 
carrier for an audio signal channel. Each of the receivers 10 includes a 
front-end or commimication interface 12 which is compatible with the 
satellite commimication charmel 8. In known manner, the transmitter 
6 and the front-end of receiver 10 (i.e. commimication interface 12) can 
comprise existing and commercially available satellite communication 
equipment specified for a baseband charmel having for example, a 256 
or 512 kiloBaud data sub-carrier. 

While the following describes a satellite based 
commimication charmel 8, however it will be appreciated that any 
otheir types of communication links can be utilized for example, 
optical fiber technology or a high serial modem lirJc over telephone 
lines. 

The communication interface 12 (or front-end) in the 
receiver 10 provides an interface which is compatible with the 
transmitter 6, as described above. The interface 12 (in the receiver 10) 
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accepts the incoming satellite signal (baseband video /audio and data 
sub-carrier) according to the standard and protocol utilized by the 
transmitter 6 and converts into a signal level which is compatible with 
the on-line de-selector 14. The commxmication interface 12 is coupled 
to the on-line de-selector 14 and supplies the de-sellector 14 with a 
signal comprising a stream of data objects 99 (Figure 8). The incoming 
signal represents a stream of data objects which are received by all the 
receivers 10, but processed according to the interests of each receiver 
10, as will now be described in detail. 

Reference is next made to Figure 8 which shows the 
organization of a stream of data objects 99. As shown, the stream 99 
comprises a series of data objects denoted generally by reference 100- 
Each object 100 comprises an object data portion 102 which contains 
data or iriformation related to the service being provided, for example, 
video images for a headline news story. In addition to the data portion 
102, the object 100 includes a start of object field 104, an object sequence 
nximber 106, an object identifier field 108 which comprises a Unique 
ID, a time stamp field 110, and an associated service field 112, and an 
end of object field 114. 

The start of object field 104, the end of object field 114 and 
the object sequence number 106 are part of the overhead information 
required to transmit and receive the object 100 as will be xmderstood by 
one skilled in the art. The start of object and end of object fields 104,114 
define the start and end of a data object 100, and can include error 
detection information such as a checksum or CRC code. 

There may be instances where the information being 
transmitted, e.g. news video images, exceed the capacity of the object 
data portion 102. In such cases the object data 102 can be transmitted as 
a sequence of objects 100 and the object sequence number field 106 is 
used to define the object number in the sequence. 

Referring still to Figure 8, the Unique ID field 108 contains 
a name or identifier which allows the object 100 to be identified by the 
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receiver 10 and selected if the object 100 is of interest as determined by 

the profile (see below). Because the data portion 102 defines what the 
object is, the Unique ID field 108 can simply contain a generic name to 
identify the object 100. This feature also allows the system 2 to use a 
5 single stream 99 to provide many different types of services, e.g. 
weather forecasting and headline news. 

The time stamp field 110 is included because certain types 
of objects, e.g. weather forecast, can become obsolete after a certain 
time. The time stamp field 110 comprises date and time of day 

1 0 information that indicates when the object 100 was created. The time 

stamp 110 can be assigned by the object builder 25 (Figure 1). As will be 
described below, the receiver 10 can use the time field 110 as a criterion 
for selecting objects 100 from the stream of objects 99. For example, ah 
older object 100 can be replaced by a newer object, as determined by the 
15 time stamp 110. 

Referring again to Figure 8, the associated service field 112 
identifies the service with which the object is associated, for example, a 
headline news service or a stock market service. 

As introduced above, the receiver 10 uses its 

2 0 profile/scheduler to "de-select" objects 100 (Figure 8) which are of 

interest to it from the continuous stream of objects 99 existing in space. 
An exemplary profile 120 is shown in Figure 6. The profile 120 is a 
record for the receiver 10 which contains specific information 122 and 
service specific information 124. The profile 120 can reside on a 

2 5 diskette (not shown) or be burned into an EPROM (not shown) which 

is read by the receiver 10. Alternatively the profile 120 can be entered 
into memory in the receiver 10 via a serial port connection 15 which 
couples the receiver 10 to a local off-line support module 17 (Figure 1). 
The primary function of the off-line support module 17 is to give the 

3 0 cable station 18 the capability to modify or augment the profile 120. 

The principle function of the profile 120 is to provide the 
receiver 10 with information so that the receiver 10 can determine 

DCID:<WO 950822eAl_L> 
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which objects 100 in the stream of objects 99 are of interest to it and 
therefore should be selected from the stream 99. The profile 120 is 
originally generated by compiling the interests of a cable television 
station 18, for example by completing a questionnaire. The interests 
5 are then compiled into a profile 120 for that station. The profile 120 is 
then forwarded to the station 18, in the form of diskette for example, 
and installed in the receiver 10. 

As shown in Figure 5, the receiver 10 specific information 
comprises a time zone designation 126, a daylight saving offset 

1 0 designation 128, a daylight saving date and time zone designation 130, 

and a language designation 132. 

The information in the daylight saying date designation 
130 is used by the receiver 10 to determine when to activate/deactivate 
daylight savings time. 
15 As described above, the objects 100 in the stream 99 can 

have more than one language. The receiver 10 uses its language 
designation 132 to determine its language, i.e. the language of objects 
that it is interested in. For example, a French designated receiver 10 
will only select those objects 100 which have an object identifier 108 
20 which implicitly signifies an object in the French language. 

Referring still to Figure 6, the service specific information 
124 comprises two general types of elements: system resource 
allowances 134 and an object cross-reference table 136. The receiver 10 
uses the systemi resource allowances information 134 to configure its 

2 5 resources for the service to be provided, e.g. memory allocation. The 

object cross-reference table 136, on the other hand, lists the objects that 
are associated with a service, provides the selection criteria by which 
the receiver 10 will select the objects 100 from the object stream 99 
(Figure 8), and also provides a local or Intemal ID for use by the 
30 receiver 10. 

In the receiver 10, the objects 100 can be identified 
according to their Unique ID 139 contained in field 108 (Figure 8) of the 
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packet 100. The objects 100 can also be renamed with a corresponding 
Internal ID 140 which is contained in the object cross-reference table 
136 as shown in Figure 7. The cross-reference table 136 is preferred 
because it provides an "anti-collision" feature which is described 
5 below. 

The cross-reference table 136 shown in Figure 7 comprises 
a list of "Unique ID" object identifiers 138 which are imique to the 
entire communication network. The cross-reference table 136 also 
includes a list of "Internal ID" object identifiers 141 for use in the 

1 0 receiver 10. The receiver 10 uses the Unique ID 139 to identify objects 

which are of interest to it* An object of interest is retained by the 
receiver 10 and then renamed according to the corresponding Internal 
ID 140, By renaming the object internally, the receiver 10 can avoid 
overwriting the object with a newly received object with the same 
15 Unique ID 139. Thus, the cross-reiference table 136 can provide an 
"anti-collision" function. The cross-reference table 136 can also be used 
to maintain compatibility between older versions of receivers 10. 

described above with reference to Figxu^e 6, the service 
specific portion 124 of the profile 120 defines a "list of objects" which 

2 0 are of interest to the receiver 10. In the alternative, the "list of objects" 

can be determined or calculated according to an algorithm in the 
receiver Id- For example, the algorithm can operate on data taken 
from the unit specific information 122 or a play-list for the receiver 10. 
According to this embodiment of the invention, the algorithm 

2 5 produces a list of objects which are of interest to the receiver 10 thereby 

the receiver 10 the capability to determine its own profile 120. 

Reference is next made to Figure 2 which shows the 
structure of the on-line de-selector 14. The on-line de-selector 14 
comprises a communication board 24 and a graphics display board 26 

3 0 which are coupled to a central processing xmit modixle 28 through a 

bus 30. The on-line de-selector 14 is based on the well-known ISA or 
PG-AT (trademark) bus architecture. The central processing unit 28 
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executes an application program which controls the operation of the 
on-line de-selector 14* In the preferred embodiment^ the central 
processing unit 28 modtile comprises an Intel 286/386/486 or Pentium 
(trademark) type microprocessor, a clock with battery backup, random 
5 access memory (1 megabyte minimum), and read only memory (not 
shown). The central processing module 28 can include other resources, 
such as DMA (Direct Memory Access) controller (not shown). 

The role of the communication board 24 is to extract 
objects 100 from the incoming data object stream 99 (Figure 7) which 

1 0 are of interest to the receiver 10. The function of the display board 26 is 

to display the objects which have been selected from tiie object 
stream by the communication board 24. The objects 100 are extracted 
according to the profile 120 which defines the interests of the receiver 
10 (see Figure 6)- The interests of the receiver 10, in turn, are 
15 determined by the client or user, e.g. the services that the cable 
television station 18 will provide its subscribers 20. Because the 
receiver 10 knows what objects it wants, the central commimication 
controller 4 does not need to know this, and therefore the need for 
addressing the receivers 10 for selected data transfer is eliminated. 

2 0 As shown in Figure 2, the communication board 24 

comprises a digital module 34. The digital module 34 is coupled to an 
integrated receiver demodulator 32 which is located upstream of the 
on-line de-selector 14, for example in the commimication interface 12. 
The ftmction of the IRD module 32 is to descramble the incoming 

2 5 baseband signal from the receiver 10 and apply error detection and 

correction to the incoming signal. The IRD module 32 demodulates 
and decompresses the baseband video signal, the audio sub-carrier and 
the data sub-carrier to recover the data object stream 99 (Figure 8). 
Once the data sub-carrier has been demodulated, the module 32 can 

3 0 apply known error detection and correction techniques. The IRD 

module 32 includes a data output 38 which is coupled to the digital 
module 34 and supplies serial digital data, e.g. the object stream 99. 

CID:<WQ: 950822eA1_L> 
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The IRD module 32 also includes an audio feed output 36 and a video 
feed output 37. The implementation of the IRD module 32 is within 
the imderstanding of those skilled in the art and comprises a known 
product which is available from Scientific Atlanta for example. 
S As described above, the digital module 34 receives and 

processes a serial digital feed 38. The digital module 34 can 
implemented using the knovm HDLC/SDLC commimication protocol 
and error correction techniques and the Intel 82530 family of 
communication processor. 
10 In laiown manner, the IRD module 32 can be pabkaged on 

an AT-st}'le board which plugs into a slot on the ISA bus. If the 
communication channel 8 is not a satellite link, then the IRD module 
32 can be repladed according to the commimicatiori protocol being 
used, for example, a high speed serial digitai stream over an optical 

1 5 fiber link. 

Referring still to Figure 2, the primary fimction of the 
digital module 34 is to extract or deselect objects 100 from the received 
object stream 99 based on the particular interests (i.e. profile 120) of the 
recieiver 10. This function is implemented in the form of a computer 

2 0 program which is described below. The digital module 34 also 

provides buffering for the demodulated data objects. 

The digital module 34 can be located on another AT-style 
board. Partitioning the IRD module 32 and the digital module 34 
allows the IRD or analog module 32 to be changed (e.g. for a different 

2 5 commimication interface) without changing the digital module 34. 

Communication between the IRD and digital modules 32,34 is 
accomplished through the serial link 38 as shown in Figure 2. 
Alternatively, the digital module 34 can be implemented as a software 
fimction in the computer program which is executed by the central 

3 0 processing unit 28. 

As shown in Figure 2, the display board 26 is also coupled 
to the ISA bus 30. The function of the display board 26 is to provide the 
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objects that have been selected by the digital module 34 in a form (e.g. 
as cable television video signals) which is suitable for consumption by 
the user or client (e.g* cable television station 18). If the data portion 
102 of the objects 100 are transmitted in a compressed format (e.g. TTFF 
5 - Tagged Image File Format using packed bit compression), the objects 
must be decompressed. 

The display board 26 includes a raster module 40. The 
raster module 40 includes memory which is used to store and process 
objects containing video images. According to the invention, there are 
1 0 two planes of raster memory: the main raster having at least two 
pages; and the overlay plane. The display board 26 processes its own 
Vertical Blanking Interval (VBI) interrupt. The display board 40 
preferably has tiie following functionalitsr: (a) 256/32768 colour display; 
(b) display resolution of 640 x 480 for NTSC based television systems; 

1 5 (c) 768 X 576 display resolution for PAL based television systems; (d) a 

text function; (e) switching between three video inputs (i.e. video 
signal feed, computer image or video feed signal overlaid with a 
computer image); (f) overlaying of the video feed signal with a 
computer image; (g) decompressing images, e.g. RLE or LZW; and (h) 

2 0 display of time of day clock. This functionality can be provided using 

known technology as will be within the imderstanding of one skilled 
in the art. The display board 26 can also be packaged on an AT-style 
board which plugs into the ISA bus 30 and rims under the control of 
the central processing tmit 28. 

2 5 The on-line de-selector 14 also includes an audio module 

42 which is used to process objects having audio information. The 
audio module 42 preferably includes the capability to switch between 
audio inputs, for example, the audio feed 36 provided by the IRD 
module 32 and a local audio feed. 

3 0 Referring still to Figure 2, the processing resources of Ae 

on-line can be augmented by peripheral boards 44. The peripheral 
boards 44 which plug into the ISA bus 30 can comprise additional 
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memory (e.g. RAM and/or Flash Disk) to increase the capacity of the 
receiver 10 , or a fax/modem board for example. 

Reference is next made to Figure 3 which shows in 
functional block diagram form an application program 50 executed by 
5 the receiver 10 according to the present invention. The applicatidn 
program 50 is based on a micro-kernel rieal-time operating system for 
example the coirunercially available QNX (trademark) system known 
to one skilled in the art. The program 50 comprises a number of tasks 
running simultaneously under different priorities. As shown in 

10 Figure 3, the application program 50 comprises seven functional 
modules: a data receptor module 52; a profile manager 54; a system 
monitor module 56; a series of service modules 5j5a to 58n; a series of 
graphic board software modules 60a to 60n; a "heartbeat" module 62; a 
utilities module 64 and a start-up module 66. 

^ ^ Referring to Figure 3, the system monitor 56 comprises a 

set of functions which manage the operation of the program 50, such 
as the queuing of tasks performed by the various modules described 
below* 

The heartbeat module 62 synchronizes the receiver 10. 
20 According to the invention, the receivers 10 in the system 2 are not 
tmder real time control of the communication controller 4, however, 
the commimication controller 4 sends a heartbeat packet periodically 
which is used by the receivers 10 to synchronize. The heartbeat packet 
indicates what the Greenwich Mean Time (GMT) will be at the next 

2 5 vertical blanking interval (VBI). Each receiver 10 receives the GMT 

update and converts it to local time according to its geographic 
location which can be determined from the profile 120. The program 
50 can use the local time to produce a time of day display for the 
overlay plane. 

3 0 The utilities module 64 provides a series of utility tasks 

and drivers. For example, the utilities module 64 can include a self- 
diagnostics function and the software interface for the off-line support 
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module 17 (Figure 2), or the software interface for supporting a fax 
modem board. 

The data receptor module 52 processes the incoming 
object data stream 99 (Figure 8). The data receptor module 52 serves as 
5 the interface to the communication processor 24 (Figure 2). The data 
receptor module 52 controls the operation of the digital module 34 
(Figure 2) to perform the following operations: (a) assembling objects 
(e.g. a video image correspondiiig to an object may be transmitted in a 
sequence of packets); (b) buffering the objects for the display processor 
10 26 (Figure 2); and (c) routing, i.e, dispatching, the objects to the 
appropriate display processor 26 (Figure 2). As shown in Figure 3, the 
data receptor 52 is coupled to the profile manager 54 which proyidefs 
access to the profile 120 in order to select and assemble the objects of 
interest to the receiver 10, The data receptor module 52 is shown in 
15 more detail in Figure 4 and described below. 

Referring to Figure 3^ the start-up module 66 initializes 
the receiver 10 when power is first applied or if there is a reset, either 
hardware or software. The receiver 10 iises the start-up module 66 to 
"boot" from an electronic storage device, e.g. floppy or hard disk drive, 

2 0 which contains all the required software and data, e.g. program 50 and 

profile 120, to iiutialize the receiver 10. 

Once the receiver 10 is initialized, the program 50, i.e. data 
receptor 52, waits for the object stream 99 to be broadcast by the 
commimication controller 4 and transmitter 6. The communication 
25 controller 4 broadcasts the object stream 99 to all the receivers 10 in the 
system 2. Each receiver 10 receives the object stream 99 and then 
decides which objects 100 are of use or interest to it. The prograin 50 
then uses one of the service modules 58a to 58n to display the objects 
of interest e.g. weather service or headline new service. 

3 0 Referring to Figure 3, each of the services modules 58a to 

58n comprises a sequencer 59a to 59n and a graphics driver 61a to 61n. 
The sequencer module 59a to 59n is a software function which displays 
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the objects stored by the data receptor 52 according to a ''play or 
sequence list". The sequence-list defines the objects to be displayed and 
their respective start times. Figure 9 shows a partial sequence list and 
is described below. 

5 The graphics driver module 61 a to 61n provides an 

interface between the sequencer 59a to 59n and the graphics board 
software 60a to 60n. In its simplest form, the graphics driver module 
61a generates the "handshakirig" required for passing object data to the 
graphics board 26 (Figure 2) for video display. 
10 Referring next to Figure 4, the data receptor module 52 

comprises a commtmications driver 68, an object assembler 70 and a 
cross-referencer 72. The commimications driver 68 provides the 
interface to the object data stream 99 which is inputted by the 
cbmmiunications board 26. The communications driver 68 allows the 

1 5 receiver 10 to be indejpendent from the form of the commimication 

channel or medium 8. The communications driver 68 can be 
implemented based on known communication protocols^ such as 
SDLC/HDLC protocol using an Intel 82530 communication chip (not 
shown) operating at 256 (or 512) KiloBaud or a serial communication 

2 0 protocol operating at 19.2 KiloBaud. The primary functiorts performed 

by the communication driver -68 are to receive each frame or packet in 
the object stream 99; to detect errors in the received frame or packet; 
and if possible replace any corrupted frames. Once a complete packet 99 
is received, the communication driver 68 forwards it to the next task/ 

2 5 i.e. the object assembler 70. 

The primary function of the object assembler 70 is to 
either "flush" or keep the data block in the data stream 99 comprising 
the object 100. If the object is of interest to the particular receiver 10, 
then the data block is written to a mass storage device 74, e.g. a hard 

3 0 disk, which comprises an "object repository". If the object 100 is not of 

interest, the object assembler 70 "flushes" the data block. The object 
assembler 70 uses the profile manager 54 to access the Profile 120 
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(Figure 6) which is stored locally to detenxiine if an object is of interest. 
The Profile 120 contaiiis a list of Object ID's which are of interest. 
Because the objects are transmitted to all the receivers 10 in the field, 
every piece of information comprises an object with a Unique ID. The 
5 object assembler 70 only looks at the Unique ID of the object 100 and is 
not concerned with the content of the object, therefore the object can 
comprise any type of file. 

Objects 100 which are of interest to the receiver 10 are 
renamed with an Internal ID 140 (Figure 7) from the cross-referencer 

10 72. The Internal ID is used as a collision avoidance function to enstire 
that an object which is receiived does not overwrite or replace an object 
which is currently being displayed. To this end, the pimcipal functions 
performed by the cross-referencer 70 are to rename the object from its 
UniquelD to its Internal ID; to ensure that there is np overlap between 

15 Internal ID assignments (i.e. "internal collisions"); and to send 
notification of Internal ID assigrxment to any other ftmctions as 
required. The cross-referericer 70 accesses the cross-reference table 136 
as shown in Figure 7. 

The object repository on the mass storage device 74 

2 0 comprises a directory which is used to access the objects that have been 
selected by the receiver 10. The directory is part of a file system which 
lists the objects that were selected by the data receptor 52 (see above)- In 
the structure of the directoiy and file system is implemented according 
to the real time operating system (see above), for example, QNX 

2 5 (trademark) platform. 

Reference is next 'made to Figure 5 which shows the 
sequencer module 59 in more detail. The sequencer module 59 is a 
function which operates on the objects 100 in order to produce a 
service which has been requested by the user or client, e.g. the cable 

3 0 television station 18 and related to the service provider 58- For 

example, there can be a service provider 58a for a headline news 
service, a service provider 58b for the financial markets, a service 

:il> <wo osnfl:>^fiAi i ■> 
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provider 58c for sports headline, and a service provider for weather 
reports 58n. If the client has subscribed to a headline news service, the 
sequencer module 59a will perform the tasks required to display 
headline new stories. These tasks can involve displaying Video images 
5 accompanied by audio to report the news, for example. In addition, a 
text message crawling along the bottom of the image can also be 
provided. The service to be provided defines the type of video images 
and the audio information which are produced by tiie receiver 10, and 
the objects associated with a service define the content of the video 

10 images and audio information. 

A feature of the system 2 according to the present 
invention is ttiat the object driven receivers 10 combined with the 
service modules 58a to 58n allow the a receiver 10 to distribute many 
services from a single source. 

■I 5 As shown in Figure 5, the sequencer module 59 comprises 

a sequencer task 76, a raster display task 78, and an overlay display task 
80. The sequencer 76 is a function which displays tfie stored objects 
according to a sequence-list 77. The function of the sequencer 76 is to 
assemble (and display) the objects 100 stored in tiie object repository 74 

2 0 according to the sequence-list or play-list 77. 

As shown in Figure 9, the sequence-list 77 defines the 
data, i.e. objects 100, to be displayed for £i service, e.g. headline news, 
and their respective start times. Each operation in the sequence list 77 
either comprises an "#include" command or a "#display" command 

2 5 according to the QNX platform. The sequencer 76 uses #include 

command to include or retrieve another file and the #display 
command to display data. As shown in Figure 9, each entry in the 
sequence list 77 includes a command field 150, a start time 152, ah end 
time 154 and a parameter field. The command field 150 specifies 

3 0 whether the entry is an #include or a #display command. The 

sequences are coded as using a count of seconds starting Simday 
morning at 0000:00:00 for example. As described above, the heartbeat 
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packet synchronizes the receiver 10 with the commiinication 
controller 4. To execute an entry in the sequencer list 77, the sequence 
76 compares the start and end time fields 152,154 to the current time in 
the receiver 10 and executes the entry if the current time is within the 
5 defined range. If synchronization is lost, then the sequencer 76 
executes a default sequence until synchronization is established. 
Because the start and end time fields 152,154 are specified, it is not 
necessary for the sequencer 76 to open the file and thereifore the 
sequencer 76 can quickly regain synchronization. 

10 The parameter field 156 provides additional parameters 

which are needed to execute the operation. For example, the 
parameter field 156 includes a sub-field 158 for specifying the video 
source, e.g. VI; a sub-field 160 for the raster plane, e.g. R; a sub-field 162 
for the overlay plane, i.e. O; a sub-field 164 for the time of day clock, i.e. 

15 C; and a sub-field 166 for the product definition name, e.g. 0102. In the 
case of an "#include" command, the pEtrameter field 156 contains tfie 
name of a file to be included, e.g./'mprevlOOaov.seq" as shown in 
Figure 10. 

The objects 100 to be displayed by the sequencer 76 can be 
2 0 displayed either on the raster plane and /or on the overlay plane of the 
graphics image as will be understood by those skilled in the art. The 
two sub-fields 160,162 define which planes are to be used. 

The raster display task 78 receives messages from the 
sequencer 76 and perfonns the operations necessary for display on the 
25 "raster plane". The raster display task 78 includes a product definition 
file 82 which tells the raster task 78 what layers comprise the image to 
be displayed on the raster plane. Figure 11 shows eight examples of 
product definitions 168 to 182. The first line, i.e. 00, of each product 
definition contains the product definition number, for example "0102" 
30 for product definition 174. Each line in the definition 174 can also 
include a description or comment. The remaining lines, i.e. 01, in the 
definition 174 comprise the layers which together form a composite 
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image to be displayed on the raster plane. Each line 01 includes a file 
name, e.g. SL231,TGA which contains the data for the layer. The files 
can include data which was received from the communication 
controller 4 through the object stream 99. The raster task 78 reads the 
5 data from the files, e.g. SL231.TGA, associated with the product from 
disk 74 and sends it to the graphics display board 26. The product 
definition 174 also includes a parameter field 175 which provides 
additional information for processing the layer. For example, the 
iparameter field 175 can specify wheither an layer is to decompressed in 

10 OPAQUE or TRANSPARENT form. Unlike known systems, the 
receiver 10 according to the present invention has no capability to 
generate graphics, e.g. line, shape or text drawing. According to the 
invention, the images are built from a series of layers which are 
decompressed on the graphics display board 26. 

15 In the event that there is fault with the required image, 

the raster task 78 includes the capability to display a default slide or 
image. This can be specified in the tedmical parameter field 175. 

The overlay display task 80 rieceives messages from the 
sequencer task 76 and handles the display in the "overlay plane". The 

2 0 overlay task 80 also includes a product definition file 84 stored on disk. 
In response to commands from the sequencer 76, the overlay task 80 
assembles the layers comprising the image according to the product 
definition 84 and passes the compressed data to the graphics display 
board 26 through the graphics driver module 61. The actual display 

2 5 and presentation of the objects is provided by the graphics board 26 

under the control of the graphics board software 60. 

As described above, the sequencer 76 performs the actions 
described by issuing a sequence of instructionis to the graphics display 
board 26 through the raster task 78 and the overlay task 80 according to 

3 0 the sequence list 77. The sequence 77 includes a series of "#include" 

files which can contain other include or display instructions. 

In operation, the sequencer 76 sequences through a list of 
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display operations while keeping in synchronization witti the internal 
dock generated by the heartbeat module 62. As required, the sequencer 
59 sends messages to the raster and overlay tasks 78,80 which prepare 
the desired images, i,e. products, for display by the graphics display 
5 board 26. The sequencer 76 also includes the capability to operate 
imder exception conditions. The exception conditions include loss of 
synchronization with the communication controller 4; loss of 
Genlock; or a sequence file is missing. The exception condition can 
also include a special warning, or advisory which is issued by the 
10 communication controller 4 for a particular service, e.g. weather 
service. 

The receiver 10 according to the present invention 
operates as a "slide machine" and the end resiilt of the service module 
58 is to produce a video output and/ or audio signal output for the 
15 service (e.g. headline news), which can be retransmitted by the cable 
television station 18 to the households 20 in the cable network 16. 

Although various preferred embodiments of the present 
invention have been described in detsdl, it will be appreciated by those 
skilled in the art, that variations may be made without departing from 
20 the spirit of the invention or the scope of tiie appended claims. 
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I CLAIM : 

A commvmication system comprising: 

(a) a transmitter having means for transmitting an 
object stream comprising one or more objects; 

(b) a plurality of receivers each including means for 
receiving said object stream, and each iricluding 
means for selecting any of said objects from said 
object stream; 

(c) means for providing a teceiver profile; 

(d) said receiver profile comprising a list of interest 
objects for said receiver; and 

(e) said means for selecting being responsive to said ' 
profile for selecting objects from said object stream 
corresponding to objects of interest 

2. The communication system as claimed in claim 1, 
wherein said receiver comprises a commtmication port and an on-line 
de-selector, said communication port including said means for 

2 0 receiving said object stream and said on-line de-selector including said 
means for selecting. 

3. The communication system as claimed in claim 1 or 2, 
wherein said means for providing a receiver profile comprises a 

2 5 diskette. 

4. The communication system as claimed in claim 2, 
wherein said on-line de-selector includes data reception means for 
receiving data from said communication port, and said data reception 

3 0 means having means for accessing said receiver profile. 

5. The communication system as claimed in claim 4, 
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wherein said means for accessing said receiver profile comprises a 
profile manager. 

6. The communication system as claimed in claim 4, 
5 wherein said data reception means comprises a communications 

driver and an object assembler, said commimications driver having 
means for interfacing said data reception means to said 
communication port and said object assembler being coupled to said 
communications port and having means for receiving said object 
10 stream and including selection means responsive to said receiver 
profile for selecting objects from said object stream according to said 
list of interest objects- 

7. The communication system as claimed in claim 6, 

1 5 wherein said data reception means includes storage meams for storing 

said selected objects for retrieval. 

8. The communication system as claimed in claim 6, 
wherein said selection means comprises means for reading a name for 

20 said object and comparing said name to said list of objects. 

9. A receivier for use in a communication system for 
receiving data, said receiver comprising: 

(a) receiver means for receiving said stream of data 

2 5 and said data comprising one or more objects; 

(b) selection means for selecting any of said objects 
from said data; 

(c) means for providing a receiver profile having a list 
of objects of interest to said receiver; and 

30 (s) said selection means being responsive to said 

profile for selecting objects from said data 
corresponding to objects of interest to said receiver. 
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10. The communication system as claimed in claim 9, 

wherein said receiver includes means for generating images from said 
selected objects. 

5 11. The communication system as claimed in claim 9, 

wherein said means for providing a receiver profile comprises a 
diskette. 

12. The communication system as claimed in claim 1, 9 or 11, 
10 wherein said object stream comprises data objects associated with a 

weather forecast service. 

13. The commimication system as claimed in claim 1, 9 or 11, 
wherein said object stream comprises objects asisociated with a 

15 headline news service. 

14. The communication system as claimed in claim 1, 9 or 11 
wherein said object stream comprises objects associated with a sports 
headline service. 

15. The communication system as claimed in claim 1, 9 or 11 
wherein said object stream comprises objects associated with a 
financial market reporting service. 
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W0 95A)8226 PCr/CA94/0050S 



8/8 

; mprevlOOacv.seq 

» • ■ 

#DIS 8000:00:00 000:00:12 VI RT 01 CI 

#blS 8000:00:12 000:00:24 VI RT PTYS$St82PCPL1 MM 

#PIS 8000:00:24 000:00:36 VI FTT PTYSSStSSPCPLl'MM 

#DI8 8000:00:36 000:00:48 VI RT PTY8$St8YSNSNl'MM 

#PI8 8000:00:48 000:00:56 V1 RT O- C- PTY8$StSYSLSL1 

#DI8 8000:00:56 ■ 000:01:00 RP PTY8$8t8lPCPL1 MM 

SEQUENCE FILE INCLUDED IN SEQUENCE LISt"(RG. 9) 

Fie. i p 

; This file is a portton of the product definition file 

00 0000 ... "Un Moment S.V.P.' 

01 SLOOb.TGA ... Logo MM V..^168 

02 SL001.TGA ... 'Un Moment S.V.P." 

00 01 00 ... Observations Automatlques 

01 SL011.TQA ... Fond Opaque 3 Zones .170 
01 SL101.TGA ... , ^ 

01 8L201.TGA ... 

01 SL253.TQA ... 

01 SL300.TGA ... 

00 0101 ... Observations Manueltes 

01 SL011.TGA ... Fond Opaque 3 Zones 172 
01 SL211.TGA ... / 

01 SL311.TGA ... ^•"'^ 

00 0102 ... Conditions Locales - Page 1 

01 SL231.TGA ... Fond Opaque 3 Zones 

01 SL202.TGA ... >174 

01 SL302.TGA ... 

01 SL322.TGA 

01 SL324.TGA 

00 0203 ... Conditions Locales - Page 2 

01 8L233.TGA ... Fond Opaque 3 Zones 
01 SL234.TGA ... 

01 8L235.TGA ... "V^ltS 

00 0404 ... Condittons Locales • ' Page 3 

01 SL232.TQA ... Fond Claque 3 Zones 
01 SL444.TQA ... 

01 SL445.TGA ... V — 178 

00 0511 ... Statlstiques 

01 SL551 .TGA ... Fond Opaque 3 Zones 

01 SLS52.TGA ... V^ISO 

00 0606 ... Phases de la Lune 

01- SL611.TGA ... Fond Opaque 3 ZonesV. ^182 



; Note: The dots *...' indicate technical parameters. 
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